# Mikroişlemci Sistemleri

Dr. Öğr. Üyesi Erkan Uslu 4 YTÜ-CE

### Ders-4 Konular

- 8255 modları
  - -Mod 0
    - LED ve Buton
    - 7 parçalı gösterge
    - 3x4 tuş tarama

- BSR (Bit set reset)
- Mod 1
- Mod 2

### 8255 Modlar



# 8255 Kontrol Yazmacı → Mod 0



8255
Kontrol
Yazmacı →
BSR



# BSR Mod Örneği

- Örnek:
- 80H adresinden itibaren ardışık çift adreslere yerleştirilmiş bir 8255'de
  - PC2'yi lojik 1 olacak şekilde
  - PC6'da ise duty cycle'ı %66 olan bir kare dalga üretecek şekilde

programlayın

# BSR Mod Örneği

MOV AL, 00000101B
 OUT 86H, AL

AGAIN MOV AL, 0xxx1101

OUT 86H, AL

**CALL** Delay

**CALL** Delay

MOV AL, 0xxx1100

OUT 86H, AL

**CALL** Delay

**JMP AGAIN** 

- Handshaking sinyalleri ile kontrollü tek yönlü veri gönderme veya almayı sağlar. (Mod 2'de handshaking sinyalleri ile çift yönlü veri iletimi)
- PORTA ve/veya PORTB Mod 1 için tek yönlü olarak veri iletimi için kullanılırken, PORTC uçları handshaking işaretleri için kullanılır.

- Grup A ve Grup B ayrı ayrı Mod 1 için programlanabilir.
- Her grupta 8 bit veri 4 bit kontrol işareti vardır.



# 8255 Mod 1 - Input

- $\overline{STB}$  : A "low" on this input loads data into the input latch
- IBF : A "high" on this output indicates that the data has been loaded into the input latch; in essence, an acknowledgement. IBF is set by  $\overline{STB}$  input being low and is reset by the rising edge of the  $\overline{RD}$  input

# 8255 Mod 1 - Input

- INTR: A "high" on this output can be used to interrupt the CPU when an input device is requesting service. INTR is set by the  $\overline{STB}$  is a "1" IBF is a "1" and INTE is a "1". It is reset by the falling edge of  $\overline{RD}$
- INTEA: Controlled by bit set/reset of PC4
- INTEB: Controlled by bit set/reset of PC2

# 8255 Mod 1 – Input Timing



## 8255 Mod 1 - Output

- $\overline{OBF}$ : goes "0" to indicate that the CPU has written data out to the specified port. The  $\overline{OBF}$  will be set by the rising edge of the  $\overline{WR}$  input and reset by  $\overline{ACK}$  input being low
- $\overline{ACK}$ : A "0" on this input informs the 82C55A that the data from Port A or Port B has been accepted

# 8255 Mod 1 - Output

• INTR: A "0" on this output can be used to interrupt the CPU when an output device has accepted data transmitted by the CPU. INTR is set when  $\overline{ACK}$  is a "1",  $\overline{OBF}$  is a "1"and INTE is a "1". It is reset by the falling edge of  $\overline{WR}$ .

# 8255 Mod 1 - Output

- INTEA: Controlled by bit set/reset of PC6
- INTEB: Controlled by bit set/reset of PC2

# 8255 Mod 1 – Output Timing



### 8255 Mod 1 – Status Word

- 8255 mod 1 için ayarlanmışsa PORTC'den yapılan okumalar STATUS WORD'dür
- OBF, IBF, INTR değerleri ile I/O için kullanılan
   PORTC uçları okunabilir

### 8255 Mod 1 – Status Word

Input



Output



 8255 Grup A Mod 1 output, 8255 Grup B Mod 1 input yönlü ayarlanarak, bunlar arasında handshaking tabanlı I/O işlemleri nasıl yapılabilir?

- Strobed bidirectional bus I/O
- Sadece Grup A mod 2 destekler
- 1 adet 8 bit çift yönlü port (PORTA), ve 5 handshaking kontrol işareti mevcuttur



- INTE 1 : Controlled by bit set/reset of PC6
- INTE 2 : Controlled by bit set/reset of PC4

# 8255 Mod 2 -Timing



### 8255 Mod 2 – Status Word

| $D_7$   | $D_6$    | $D_5$   | $D_4$    | $D_3$    | $D_2$   | $D_1$ | $D_0$ |
|---------|----------|---------|----------|----------|---------|-------|-------|
| $OBF_A$ | $INTE_1$ | $IBF_A$ | $INTE_2$ | $INTR_A$ |         |       |       |
|         |          |         |          |          |         |       |       |
| GROUP A |          |         |          |          | GROUP B |       |       |

8255 Modlar: Özet Tablo

|                 | MODE 0 |     |  |
|-----------------|--------|-----|--|
|                 | IN     | OUT |  |
| PA <sub>0</sub> | IN     | OUT |  |
| PA <sub>1</sub> | IN     | OUT |  |
| PA <sub>2</sub> | IN     | OUT |  |
| PA <sub>3</sub> | IN     | OUT |  |
| PA <sub>4</sub> | IN     | OUT |  |
| PA <sub>5</sub> | IN     | OUT |  |
| PA <sub>6</sub> | IN     | OUT |  |
| PA <sub>7</sub> | IN     | OUT |  |
| PB <sub>0</sub> | IN     | OUT |  |
| PB <sub>1</sub> | IN     | OUT |  |
| PB <sub>2</sub> | IN     | OUT |  |
| PB <sub>3</sub> | IN     | OUT |  |
| PB <sub>4</sub> | IN     | OUT |  |
| PB <sub>5</sub> | IN     | OUT |  |
| PB <sub>6</sub> | IN     | OUT |  |
| PB <sub>7</sub> | IN     | OUT |  |
| PC <sub>0</sub> | IN     | OUT |  |
| PC <sub>1</sub> | IN     | OUT |  |
| PC <sub>2</sub> | IN     | OUT |  |
| PC <sub>3</sub> | IN     | OUT |  |
| PC <sub>4</sub> | IN     | OUT |  |
| PC <sub>5</sub> | IN     | OUT |  |
| PC <sub>6</sub> | IN     | OUT |  |
| PC <sub>7</sub> | IN     | OUT |  |

| MODE 1 |       |  |  |  |
|--------|-------|--|--|--|
| IN     | OUT   |  |  |  |
| INTRB  | INTRB |  |  |  |
| IBFB   | OBFB  |  |  |  |
| STBB   | ACKB  |  |  |  |
| INTRA  | INTRA |  |  |  |
| STBA   | 1/0   |  |  |  |
| IBFA   | 1/0   |  |  |  |
| 1/0    | ACKA  |  |  |  |
| 1/0    | OBFA  |  |  |  |

